package com.leetcode.leetcode3;

/**
 * 寻找重复数
 * 给定一个包含 n + 1 个整数的数组 nums ，其数字都在 [1, n] 范围内（包括 1 和 n），可知至少存在一个重复的整数。
 *
 * @author luhd
 * @date 2024-04-26
 */
public class Practice287 {

    /**
     * 示例 1：
     *
     * 输入：nums = [1,3,4,2,2]
     * 输出：2
     * 示例 2：
     *
     * 输入：nums = [3,1,3,4,2]
     * 输出：3
     * 示例 3 :
     *
     * 输入：nums = [3,3,3,3,3]
     * 输出：3
     */
    public static void main(String[] args) {
        int[] nums = {3,1,3,4,2};
        System.out.println(findDuplicate(nums));
    }

    public static int findDuplicate(int[] nums) {
        int[] a = new int[nums.length];
        for (int i = 0; i < nums.length; i++) {
            a[nums[i]]++;
        }
        for (int i = 0; i < nums.length; i++) {
            if (a[i] >1) {
                return i;
            }
        }
        return 0;
    }
}